package com.zhentao.mapper;

import com.zhentao.classManager.dto.ExaminationDto;
import com.zhentao.classManager.pojo.TUser;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.zhentao.classManager.pojo.excel.ExcelClass;
import com.zhentao.classManager.pojo.vo.ExaminationVo;
import com.zhentao.classManager.pojo.vo.PaperInfoVo;
import com.zhentao.classManager.pojo.vo.StudentVo;
import com.zhentao.classManager.pojo.vo.TeacherVo;
import com.zhentao.domain.StudentCount;
import com.zhentao.domain.vo.TuserVO;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
* @author song-xinhang
* @description 针对表【t_user】的数据库操作Mapper
* @createDate 2024-07-24 10:08:50
* @Entity com.zhentao.classManager.pojo.TUser
*/
public interface TUserMapper extends BaseMapper<TUser> {

    /**
     * 查询所有教师信息
     * @return
     * */
    List<TuserVO> selectTeacherAll();

    /**
     * 查询所有班级信息
     * @return
     * */
    List<ExcelClass> selectTeacher();

    /**
     * 根据教师id查询班级信息
     * @param userId
     * @return
     * */
    List<TeacherVo> selectTeacherClass(Integer userId);


    /**
     * 根据学生id查询考试信息
     * @param studentId
     * @return
     * */
    List<StudentVo> selectStudentExam(Integer studentId);

    /**
     * 根据班级id查询考试信息
     * @param examinationDto
     * @return
     * */
    List<ExaminationVo> selectExaminationInfo(@Param("dto") ExaminationDto examinationDto);

    /**
     * 根据考试id查询考试题目信息
     * @param examinationId
     * @return
     * */
    List<PaperInfoVo> examinationQuestion(Integer examinationId);

    /**
     * 根据教师id查询班级信息
     * @param teacherId
     * @return
     */
    List<StudentCount> selectTeacherClassInfo(Integer teacherId);

    /**
     * 根据教师id查询考试信息以及题目总数
     * @param userId
     * @return
     */
    List<StudentCount> selectTeacherExamInfo(@Param("userId") Integer userId);
}